## **RV32I Base Instruction Set**

## (Assembled by jinho.rho)

| 24   20   20   27   27   27        | 04 00 00 04                              | 40 40 47 46 17                           | 144 40 15                  |                          |                             |                         |                       |                         |                                                 |              |                                                                                                                                                                                                                                 |
|------------------------------------|------------------------------------------|------------------------------------------|----------------------------|--------------------------|-----------------------------|-------------------------|-----------------------|-------------------------|-------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25<br>Funct7 (7) | 24 23 22 21 20<br>Regitster Source 2 (5) | 19 18 17 16 15<br>Regitster Source 1 (5) | 14   13   12<br>Funct3 (3) |                          | 6 5 4 3 2 1 0<br>Opcode (7) | TYPE                    | MNEMONIC              | NAME                    | Descript                                        | Note         |                                                                                                                                                                                                                                 |
| 0 0 0 0 0 0 0                      | rs2                                      | rs1                                      | 0 0 0                      | rd                       | 0 1 1 0 0 1 1               |                         | ADD                   | ADD                     | rd = rs1 + rs2                                  |              | add v7 v5 v6 # v7 - v5 i v6                                                                                                                                                                                                     |
| 0 1 0 0 0 0 0                      | rs2                                      | rs1                                      | 0 0 0                      | rd                       | 0 1 1 0 0 1 1               | R-TYPE                  | SUB                   | SUB                     | rd = rs1 - rs2                                  |              | add x7, x5, x6 # x7 = x5 + x6                                                                                                                                                                                                   |
|                                    | rs2                                      | rs1                                      | 0 0 0                      | rd                       | 0 1 1 0 0 1 1               |                         | -                     |                         | -                                               |              | sub x7, x5, x6 # x7 = x5 - x6                                                                                                                                                                                                   |
| 0 0 0 0 0 0 0                      |                                          |                                          |                            |                          |                             |                         | SLL                   | Shift Left Logical      | rd = rs1 << rs2                                 | -            | sll x7, x5, x6 # x7 = x5 << x6<br>srl x7, x5, x6 # x7 = x5 >> x6<br>sra x7, x5, x6 # x7 = x5 >>> x6<br>slt x7, x5, x6 # x7 = 1 if x5 < x6 else 0<br>sltu x7, x5, x6 # x7 = 1 if x5 < x6 else 0<br>xor x7, x5, x6 # x7 = x5 ^ x6 |
| 0 0 0 0 0 0 0                      | rs2                                      | rs1                                      | 1 0 1                      | rd                       | 0 1 1 0 0 1 1               |                         | SRL                   | Shift Right Logical     | rd = rs1 >> rs2                                 |              |                                                                                                                                                                                                                                 |
| 0 1 0 0 0 0 0                      | rs2                                      | rs1                                      | 1 0 1                      | rd                       | 0 1 1 0 0 1 1               |                         | SRA                   | Shift Right Arith*      | rd = rs1 >>> rs2                                | msb-extends  |                                                                                                                                                                                                                                 |
| 0 0 0 0 0 0 0                      | rs2                                      | rs1                                      | 0 1 0                      | rd                       | 0 1 1 0 0 1 1               |                         | SLT                   | Set Less Than           | rd = (rs1 < rs2) ? 1:0                          | ļ .          |                                                                                                                                                                                                                                 |
| 0 0 0 0 0 0                        | rs2                                      | rs1                                      | 0 1 1                      | rd                       | 0 1 1 0 0 1 1               |                         | SLTU                  | Set Less Than (U)       | rd = (rs1 < rs2) ? 1:0                          | zero-extends |                                                                                                                                                                                                                                 |
| 0 0 0 0 0 0 0                      | rs2                                      | rs1                                      | 1 0 0                      | rd                       | 0 1 1 0 0 1 1               |                         | XOR                   | XOR                     | rd = rs1 ^ rs2                                  |              |                                                                                                                                                                                                                                 |
| 0 0 0 0 0 0 0                      | rs2                                      | rs1                                      | 1 1 0                      | rd                       | 0 1 1 0 0 1 1               |                         | OR                    | OR                      | rd = rs1   rs2                                  |              | or x7, x5, x6 # x7 = x5   x6                                                                                                                                                                                                    |
| 0 0 0 0 0 0 0                      | rs2                                      | rs1                                      | 1 1 1                      | rd                       | 0 1 1 0 0 1 1               |                         | AND                   | AND                     | rd = rs1 & rs2                                  |              | and x7, x5, x6 # x7 = x5 & x6                                                                                                                                                                                                   |
| 31 30 29 28 27 26 25               | 24 23 22 21 20                           | 19 18 17 16 15                           | 14 13 12                   | 11 10 9 8 7              | 6 5 4 3 2 1 0               | VI .                    |                       |                         | 1                                               |              |                                                                                                                                                                                                                                 |
| immediate (7)                      | shift amount (5)                         | Regitster Source 1 (5)                   | Funct3 (3)                 | Register Destination (5) | Opcode (7)                  | TYPE                    | MNEMONIC              | NAME                    | Descript                                        | Note         |                                                                                                                                                                                                                                 |
| * * *                              | * *                                      |                                          |                            |                          |                             |                         | LD                    | Land Dida               | ad A4(as4 . issue)(0.7)                         |              |                                                                                                                                                                                                                                 |
| imm[11:                            |                                          | rs1                                      | 0 0 0                      | rd                       | 0 0 0 0 0 1 1               | -                       | LB                    | Load Byte               | rd = M[rs1+imm][0:7]                            | -            | lb x5, 0(x10) # Load byte from memory                                                                                                                                                                                           |
| imm[11:0]                          |                                          | rs1                                      | 0 0 1                      | rd                       | 0 0 0 0 0 1 1               | L-TYPE                  | LH                    | Load Half               | rd = M[rs1+imm][0:15]                           |              | lh x5, 0(x10) # Load halfword from memory lw x5, 0(x10) # Load word from memory                                                                                                                                                 |
| imm[11:0]                          |                                          | rs1                                      | 0 1 0                      | rd                       | 0 0 0 0 0 1 1               |                         | LW                    | Load Word               | rd = M[rs1+imm][0:31]                           |              |                                                                                                                                                                                                                                 |
| imm[11:0]                          |                                          | rs1                                      | 1 0 0                      | rd                       | 0 0 0 0 0 1 1               |                         | LBU                   | Load Byte (U)           | rd = M[rs1+imm][0:7]                            | zero-extends | lbu x7, 4(x10)                                                                                                                                                                                                                  |
| imm[11:0]                          |                                          | rs1                                      | 1 0 1                      | rd                       | 0 0 0 0 0 1 1               |                         | LHU                   | Load Half (U)           | rd = M[rs1+imm][0:15]                           | zero-extends | lhu x7, 6(x10)                                                                                                                                                                                                                  |
| imm[11:0]                          |                                          | rs1                                      | 0 0 0                      | rd                       | 0 0 1 0 0 1 1               | 1<br>1<br>1<br>1 I-TYPE | ADDI                  | ADD Immediate           | rd = rs1 + imm                                  |              | addi x7, x5, 10  # x7 = x5 + 10                                                                                                                                                                                                 |
| imm[11:0]                          |                                          | rs1                                      | 0 1 0                      | rd                       | 0 0 1 0 0 1 1               |                         | SLTI                  | Set Less Than Imm       | rd = (rs1 < imm) ? 1 : 0                        |              | slti x7, x5, 10 # x7 = 1 if x5 < 10 else 0                                                                                                                                                                                      |
| imm[11:0]                          |                                          | rs1                                      | 0 1 1                      | rd                       | 0 0 1 0 0 1 1               |                         | SLTIU                 | Set Less Than Imm (U)   | rd = (rs1 < imm) ? 1 : 0                        |              | sltiu x7, x5, 10 # x7 = 1 if x5 < 10 else 0                                                                                                                                                                                     |
| imm[11:0]                          |                                          | rs1                                      | 1 0 0                      | rd                       | 0 0 1 0 0 1 1               |                         | XORI                  | XOR Immediate           | rd = rs1 ^ imm                                  |              | xori x7, x5, 0xFF # x7 = x5 ^ 0xFF                                                                                                                                                                                              |
| imm[11:0]                          |                                          | rs1                                      | 1 1 0                      | rd                       | 0 0 1 0 0 1 1               |                         | ORI                   | OR Immediate            | rd = rs1   imm                                  |              | ori x7, x5, 0x0F # x7 = x5   0x0F                                                                                                                                                                                               |
| imm[11:                            | :0]                                      | rs1                                      | 1 1 1                      | rd                       | 0 0 1 0 0 1 1               |                         | ANDI                  | AND Immediate           | rd = rs1 & imm                                  |              | andi x7, x5, 0xF0 # x7 = x5 & 0xF0                                                                                                                                                                                              |
| 0 0 0 0 0 0                        | shamt                                    | rs1                                      | 0 0 1                      | rd                       | 0 0 1 0 0 1 1               |                         | SLLI                  | Shift Left Logical Imm  | rd = rs1 << shamt[0:4]                          |              | slli x7, x5, 4 # x7 = x5 << 4                                                                                                                                                                                                   |
| 0 0 0 0 0 0                        | shamt                                    | rs1                                      | 1 0 1                      | rd                       | 0 0 1 0 0 1 1               |                         | SRLI                  | Shift Right Logical Imm | rd = rs1 >> shamt[0:4]                          |              | srli x7, x5, 4 # x7 = x5 >> 4                                                                                                                                                                                                   |
| 0 1 0 0 0 0 0                      | shamt                                    | rs1                                      | 1 0 1                      | rd                       | 0 0 1 0 0 1 1               |                         | SRAI                  | Shift Right Arith Imm   | rd = rs1 >>> shamt[0:4]                         |              | srai x7, x5, 4 # x7 = x5 >>> 4                                                                                                                                                                                                  |
|                                    |                                          |                                          |                            |                          |                             |                         |                       |                         | 1                                               |              |                                                                                                                                                                                                                                 |
| 31 30 29 28 27 26 25               |                                          |                                          |                            |                          | 6 5 4 3 2 1 0               | TYPE                    | MNEMONIC              | NAME                    | Descript                                        | Note         |                                                                                                                                                                                                                                 |
| immediate (7)                      | Regitster Source 2 (5)                   | Regitster Source 1 (5)                   | Funct3 (3)                 | immediate (5)            | Opcode (7)                  |                         |                       |                         | ·                                               |              |                                                                                                                                                                                                                                 |
| imm[11:5]                          | rs2                                      | rs1                                      | 0 0 0                      | imm[4:0]                 | 0 1 0 0 0 1 1               |                         | SB                    | Store Byte              | M[rs1+imm][0:7] = rs2[0:7]                      |              | sb x6, $\theta(x10)$ # Store byte to memory                                                                                                                                                                                     |
| imm[11:5]                          | rs2                                      | rs1                                      | 0 0 1                      | imm[4:0]                 | 0 1 0 0 0 1 1               | S-TYPE                  | SH                    | Store Half              | M[rs1+imm][0:15] = rs2[0:15]                    |              | sh x6, $\theta(x10)$ # Store halfword to memory                                                                                                                                                                                 |
| imm[11:5]                          | rs2                                      | rs1                                      | 0 1 0                      | imm[4:0]                 | 0 1 0 0 0 1 1               |                         | SW                    | Store Word              | M[rs1+imm][0:31] = rs2[0:31]                    |              | sw x6, 0(x10) # Store word to memory                                                                                                                                                                                            |
|                                    |                                          |                                          |                            |                          |                             |                         |                       |                         | •                                               |              |                                                                                                                                                                                                                                 |
| 31 30 29 28 27 26 25               |                                          |                                          |                            |                          | 6 5 4 3 2 1 0               | TYPE                    | MNEMONIC              | NAME                    | Descript                                        | Note         |                                                                                                                                                                                                                                 |
| immediate (7)                      | Regitster Source 2 (5)                   | Regitster Source 1 (5)                   | Funct3 (3)                 | immediate (5)            | Opcode (7)                  |                         |                       |                         |                                                 |              |                                                                                                                                                                                                                                 |
| imm[12][10:5]                      | rs2                                      | rs1                                      | 0 0 0                      | imm[4:1][11]             | 1 1 0 0 0 1 1               | В-ТҮРЕ                  | BEQ                   | Branch ==               | if(rs1 == rs2) PC += imm                        |              | beq x5, x6, label # Jump to label if x5 == x6 bne x5, x6, label # Jump to label if x5 != x6 blt x5, x6, label # Jump to label if x5 < x6 bge x5, x6, label # if x5 >= x6, jump                                                  |
| imm[12][10:5]                      | rs2                                      | rs1                                      | 0 0 1                      | imm[4:1][11]             | 1 1 0 0 0 1 1               |                         | BNE                   | Branch !=               | if(rs1 != rs2) PC += imm                        |              |                                                                                                                                                                                                                                 |
| imm[12][10:5]                      | rs2                                      | rs1                                      | 1 0 0                      | imm[4:1][11]             | 1 1 0 0 0 1 1               |                         | BLT                   | Branch <                | if(rs1 < rs2) PC += imm                         |              |                                                                                                                                                                                                                                 |
| imm[12][10:5]                      | rs2                                      | rs1                                      | 1 0 1                      | imm[4:1][11]             | 1 1 0 0 0 1 1               |                         | BGE                   | Branch ≥                | if(rs1 >= rs2) PC += imm                        |              |                                                                                                                                                                                                                                 |
| imm[12][10:5]                      | rs2                                      | rs1                                      | 1 1 0                      | imm[4:1][11]             | 1 1 0 0 0 1 1               |                         | BLTU                  | Branch < (U)            | if(rs1 < rs2) PC += imm                         |              | bltu x5, x6, label # if x5 < x6, jump (unsigned                                                                                                                                                                                 |
| imm[12][10:5]                      | rs2                                      | rs1                                      | 1 1 1                      | imm[4:1][11]             | 1 1 0 0 0 1 1               |                         | BGEU                  | Branch ≥ (U)            | if(rs1 >= rs2) PC += imm                        |              | bgeu x5, x6, label # if x5 >= x6, jump (unsigne                                                                                                                                                                                 |
|                                    |                                          | 19 18 17 16 15                           |                            |                          |                             |                         |                       |                         |                                                 |              |                                                                                                                                                                                                                                 |
| 31 30 29 28 27 26 25               |                                          | 14 13 12                                 |                            | 6 5 4 3 2 1 0            | TYPE                        | MNEMONIC                | NAME                  | Descript                | Note                                            |              |                                                                                                                                                                                                                                 |
|                                    | immediate (20)                           | Register Destination (5)                 | Opcode (7)                 |                          |                             |                         | _ 2501-p1             |                         |                                                 |              |                                                                                                                                                                                                                                 |
|                                    | imm[31:12]                               | rd                                       | 0 1 1 0 1 1 1              | LU-TYPE                  | LUI                         | Load Upper Imm          | rd = imm << 12        |                         | lui x5, 0x10000 # Load upper immediate          |              |                                                                                                                                                                                                                                 |
|                                    | imm[31:12]                               | rd                                       | 0 0 1 0 1 1 1              | AU-TYPE                  | AUIPC                       | Add Upper Imm to PC     | rd = PC + (imm << 12) |                         | auipc x5, 0x10000 # Upper immediate to PC       |              |                                                                                                                                                                                                                                 |
|                                    | imm[20][10:1][11][19                     | rd                                       | 1 1 0 1 1 1 1              | J-TYPE                   | JAL                         | Jump And Link           | rd = PC + 4; PC+= imm |                         | jal x1, func # Jump to func, save return addres |              |                                                                                                                                                                                                                                 |
|                                    |                                          |                                          |                            |                          |                             |                         | 3712                  | Jump Furd Ellik         | 14 = 10 + 4, 10 = 111111                        |              | Jai XI, Tune # Jump to Tune, Save return address                                                                                                                                                                                |